

CLAIMS

What is claimed is:

1. A method, comprising:
  - creating a first descriptor to correspond to a first data block; and
  - placing the first descriptor in a descriptor ring according to a striping policy to prevent false sharing of a cache line of the computer system.
2. The method of claim 1 wherein the striping policy comprises placing the first descriptor in the descriptor ring wherein the first descriptor and a second descriptor in the descriptor ring to not share the cache line when the second descriptor is requested, the first descriptor to be the next descriptor requested from the descriptor ring after the second descriptor.
3. The method of claim 2 wherein a processor of the plurality of processors is assigned to the first descriptor according the following relationship:

Processor Assignment = Descriptor\_Position mod N,

where Descriptor\_Position is a descriptor ring position of the first descriptor and N is the total number of processors of the plurality of processors.
4. The method of claim 1 wherein the plurality of processors share a cache line, wherein the cache line is longer than the first descriptor.

5. The method of claim 4 wherein the cache line is 64 bytes long and the first descriptor is 16 bytes long.

6. The method of claim 1 wherein the first data block to be received at an I/O device of the computer system.

7. The method of claim 1 wherein the first data block is prepared at the computer system to be sent to the I/O device.

8. An article of manufacture comprising:

a machine-readable medium including a plurality of instructions which when executed perform operations comprising:

allocating a first receive buffer at a computer system including a plurality of processors, the receive buffer to store a first packet received at a network interface card (NIC) of the computer system;

creating a first descriptor corresponding to the first receive buffer; and placing the first descriptor in a descriptor ring according to a striping policy to prevent false sharing of a cache line of the computer system.

9. The article of manufacture of claim 8 wherein the striping policy comprises placing the first descriptor in the descriptor ring wherein the first descriptor and a second descriptor in the descriptor ring to not share the cache line when the second

descriptor is requested, the first descriptor to be the next descriptor requested from the descriptor ring after the second descriptor.

10. The article of manufacture of claim 9 wherein the first descriptor is assigned to a processor of the plurality of processors according the following relationship:

$$\text{Processor Assignment} = \text{Descriptor\_Position} \bmod N,$$

where Descriptor\_Position is a descriptor ring position of the first descriptor and N is the total number of processors of the plurality of processors.

11. The article of manufacture of claim 8 wherein the plurality of instructions are embodied in a NIC device driver associated with the NIC.

12. The article of manufacture comprising:

a machine-readable medium including a plurality of instructions which when executed perform operations comprising:

creating a first descriptor at a computer system including a plurality of processors, the first descriptor to correspond to a first packet to be transmitted by a network interface card (NIC) of the computer system; and

placing the first descriptor in a descriptor ring according to a striping policy to prevent false sharing of a cache line of the computer system.

13. The article of manufacture of claim 12 wherein the striping policy comprises placing the first descriptor in the descriptor ring wherein the first descriptor and a

second descriptor in the descriptor ring to not share the cache line when the second descriptor is requested, the first descriptor to be the next descriptor requested from the descriptor ring after the second descriptor.

14. The article of manufacture of claim 13 wherein the first descriptor is assigned to a processor of the plurality of processors according the following relationship:

Processor Assignment = Descriptor\_Position mod N,

where Descriptor\_Position is a descriptor ring position of the first descriptor and N is the total number of processors of the plurality of processors.

15. The article of manufacture of claim 12 wherein the plurality of instructions are embodied in a NIC device driver associated with the NIC.

16. A computer system, comprising:

a plurality of network interface cards (NICs);

a plurality of processors communicatively coupled to each of the plurality of NICs; and

a storage device operatively coupled to the plurality of processors, the storage device including a plurality of instructions which when executed by a processor of the plurality of processors perform operations comprising:

creating a first descriptor to correspond to a first packet; and  
placing the first descriptor in a descriptor ring according to a striping policy to prevent false sharing of a cache line of the computer system.

17. The computer system of claim 16 wherein the striping policy comprises placing the first descriptor in the descriptor ring wherein the first descriptor and a second descriptor in the descriptor ring to not share the cache line when the second descriptor is requested, the first descriptor to be the next descriptor requested from the descriptor ring after the second descriptor.

18. The computer system of claim 17 wherein the first descriptor is assigned to a processor of the plurality of processors according the following relationship:

Processor Assignment = Descriptor\_Position mod N,  
where Descriptor\_Position is a descriptor ring position of the first descriptor and N is the total number of processors of the plurality of processors.

19. The computer system of claim 16 wherein execution of the plurality of instructions further perform operations comprising receiving the first packet at a NIC of the plurality of NICs.

20. The computer system of claim 16 wherein execution of the plurality of instructions further perform operations comprising preparing the first packet at the computer system, the first packet to be transmitted from a NIC of the plurality of NICs.